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@ Central processing unit for executing Instructions of variable length. 



© A central processing unit for executing instructions of 
variable length in which an operand specifier for specifying 
the addressing mode of an operand is independent of an 
operation code for ascertaining the kind of an operation and 
the number of operands. Each operand specifier is formed 
of one or more data bytes, and has a stop bit flag indicating 
whether or not the particular operand specifier is the last 
operand specifier. By adding the stop bit flag, the operand 
specifier can be shared, and different processing can be 
01 executed with an identical operation code. In a case where, 
when operation code decoding means has provided an 
output indicative of the last operand, the stop bit flag is not 
detected In the corresponding operand specifier, the corres- 
ponding Instruction is detected as an error. 
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HITACHI, LTD. . 
AND 

HITACHI ENGINEERING CO.,LTD. 
EPA-25 821 

CENTRAL PROCESSING UNIT FOR EXECUTING 
INSTRUCTIONS OF VARIABLE LENGTH 
The present invention relates to a central 
processing unit for executing instructions of 
variable length in which an operand specifier for 
specifying the addressing mode of an operand is .indep- 
5 endent of an operation code for ascertaining the kind 
of processing of an operation and the number of 
operands . 

In general, in a variable-length instruction 
scheme, even in case of an identical operation code, - 

10 instructions have various lengths. Moreover, although 
the head field of each instruction is always an 
operation code, the other parts have various signi- 
ficances. Therefore, the significances of fields in 
instructions are not uniquely determined. 

15 In addition, an operand specifier included in 

an instruction has its length varied in correspondence 
with an addressing mode. Therefore, even in case of 
an identical operation code, the lengths of instruc-' 
tions take various values. 

20 As instruction schemes having operand specifiers 

of variable lengths, two typical known examples will 
be mentioned below. 

One of them is instruction formats at the time 



0073424 

August 19, 1982 



- 2 - 



0073424 



when Burroughs Corporations Computer B1700 Is used 
as a COBGL/RPG-oriented architecture. This is des- 
cribed in "B1700 COBOL/RPG-S-Language, 1058823-015, 
Copyright 1973, .Burroughs Corporation". 

The other example is the instruction scheme 
having operand specifiers to become variable in . 
length, which the architecture of DEC (Digital 
Equipment Corporation) • s Computer VAXll/780 possesses. 
This is described in "VAXll Architecture Handbook, 
Copyright 1979" and U. S. P. No. 4,236,206. 

The two conventional instruction schemes men- 
tioned here have the feature that parts for specifying 
the format of an operand and an addressing mode are 
prescribed by an operand specifier of variable length 
and are independent of an operation code. 

With the conventional variable-length instruc- 
tions, however, the number of operands to be 
processed and operand specifiers for specifying the 
addressing modes of the operands to be processed are 
held in correspondence at 1-to-l. For example, to 
the two processing (operations) of: 
A + B — > B 
A + B — > C 
two operation codes need to be allotted. 

That is, in the processing of A + B — >B,' it 
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needs to tie especially prescribed by the operation 
code to process the two operands and to use the 
. second operand twice. 

If, in the processing of A + B — ^B, the number 
5 of operands is made three and three operand specifiers 
are prepared, the distinction between A + B — >B and 
A + B — need not be conscious of, but the two, 
quite identical operand specifiers need to be provided 
in the processing of A + B — > B. Unfavorably, this 

10 lowers the packaging efficiency of a memory drastically 
when the operand specifier itself assumes plural 
bytes (in general, a long one assumes 7 bytes). 

Originally, distinguishing the processing of 
A + B — >B and A + B — >C by the use of the operation 

15 codes has been done in order to raise the packaging 
efficiency of a memory. That is, in the instruction 
of A + B — ^B, the operation code is used to define 
that the number of operands is two and that the 
second operand specifier is used twice, whereby the 

20 two operand specifiers are made sufficient, 

Although the example of A + B — >B has been 
referred to, the processing of A - B — >B is similar, 
and the above applies to all examples in which A and 
B are operated, whereupon the result is stored in B./ 

25 in general, they are expressed as A (Og) B— >B. 
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In this manner, with the conventional variable- 
length instructions, the processing which uses the 
same operand a plurality of times needs to be dis- 
tinguished from another processing of the same func- 
tion by the operation code, and the number of processing 
which can be specified by the operation code is limited. 

In addition, in the scheme in which the number of 
operand specifiers is ascertained by an operation 
code, .the detection of errors in instructions has 
O been difficult because the relationship between the 
number of operands and that of the operand specifiers 
cannot be checked. 

The principal object of -the present invention " 
is to provide a central processing unit for executing 
5' instructions of variable length that permit operand 
specifiers to be shared without distinguishing them 
by the use of operation codes. 

Another object of the present invention is to 
provide a central processing unit which enhances 
error detectibility for instructions of variable 
length that permit a plurality of operands to share 
operand specifiers. 

According to the principal feature of the present 
invention, end information (hereinbelow, termed "end/ 
flags") of operand specifiers are added to specific 
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fields of the operand specifiers for specifying the 
addressing modes of operands; only the last operand 
specifier has the end flag set at "1"; and when 
operand specifier decode means has detected said end 
5 flag set at "1", the particular operand specifier 
is Judged to be the last forming one instruction, 
whereupon the instruction is executed* . As will be 
concretely described later, in a case where the 
operand specifier decode means has detected the set . 
10 of the end flag (indicating that the particular 

operand specifier is the last) before operation code 
decode means provides an information on the last 
operand, the operand corresponding to the particular 
operand specifier is used again. In this case, the 
15 last operand specifier is repeatedly used until the 
number of operands ascertained by. the operation code 
is reached. 

As another feature of the present invention, the 
error of an instruction is detected on the basis of 

20 the content of the end flag and the number of operands 
ascertained by the operation code. Concretely, in a 
case where the operand specifier decode means does not 
detect the set of the end flag when the operation 
code decode means has provided the information on the 

"25 last operand, the particular instruction is detected 



- 6 - 



0073424 



as an error. 

Other objects and features of the present 
invention will become apparent from the appended 
claims, in the light of the following description 
taken in conjunction with the drawings in which: 

Figure 1 is a fundamental conceptual diagram of 
a data processing system to which the present inven- 
tion is applied; 

Figures 2(A) and 2(B) are diagrams showing 
examples of the format of a variable-length instruc- 
tion and the format of an operand specifier for use 
in 1ft e present invention; 

Figure 3 is a block diagram of a concrete 
embodiment in the case where the present invention 
is applied to a central processing unit in Figure 1; 

Figure 4 is a block diagram ti£ a concrete embodi- 
ment of a decode unit in Figure 3 as forms the essen- 
tial portion of the present invention; 

Figure 5 shows the formats of operand specifiers 
for use in the explanation of Figure 4; 

Figure 6 is a block diagram of an embodiment 
of a decode sequence controller (63) in Figure. 4; 

Figure 7 is an explanatory view for use in the 
explanation of the operations of an operand specifier 
decoder (66); and 
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Figure 8 is a circuit diagram of an embodiment 
of a decode controller (65). 

Figure 1 is a fundamental conceptual diagram of 
a data processing system to which the present inven- 
5 t ion is applied. 

A memory unit 1 and a plurality of central proces- 
sing units 2 are connected by a common bus 3, through 
which information can be exchanged therebetween. 

The memory unit 1 is constructed of a memory U 
10 which stores instructions and operands to be handled 
by the instructions, and a memory control unit 12 
which controls the reading and writing of the instruc- 
tions and operands. The memory 11 and the memory 
control unit 12 are connected by a memory bus* 13. 
15 Since the memory unit 1 is not directly pertinent 

to the subject matter of the present invention and its 
construction and operations are well known, the 
detailed explanation of this part is omitted. 

The central processing units 2 can be connected 
20 to the common bus 3 in a plural number (in the illust-. 
ration, two), and they access instructions and 
operands from the memory unit 1 so as to process the 
instructions in succession, respectively. 

Here is illustrated an example wherein, in order* 
25 to process instructions at high speed, instructions 
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and operands once read out are respectively copied 
in an instruction cache 21 (fast buffer memory) 
and an operand cache 22 (fast buffer memory), and 
an I unit 23 which fetches and decodes instructions 
and calculates operand addresses, and an E unit which 
fetches operands and executes instructions perform 
pipeline processing, respectively. 

The usage of such instruction cache or operand 
cache, or the pipeline processing of the I unit and 
E unit has been known in itself. 

Now, Figure 2(A) shows an example of the format 
of an variable-length instruction which the central 
processing unit 2 handles. 

One instruction is constructed of one operation 
code (usually called "ope-code") OP, and one or more 

operand specifiers 0S lf 0S 2 • . and OS n each of 

which accompanies an end flag S. 

The operation code OP indicates the content of 
processing (the sort of processing) of the particular 
instruction, the number of operands necessary for 
the processing, and the properties (data length, 
distinction between read A/rite, data type: fixed 
point/floating point etc.) of the operands. 

It is composed. of one to several bytes. 

As described before, the operand specifier 
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specifies the addressing mode of an operand, and 
whether or not the particular operand specifier 
is the last one. The length of the operand specifier 
is one to several bytes, and it varies depending 

5 upon the addressing mode and is independent of the 
content of the operation code. 

The operand specifiers are arrayed in the order 
of operands to be used in the corresponding instruc- 
tion, and only the last operand specifier has the end 

10 flag S set at "1". In a case where the number of the 
operand specifiers decoded in one instruction is 
smaller than the operand number indicated by the 
operation code OP, the operand corresponding to the 
last operand specifier is repeatedly used. 

15 While the repeated use of the same operand is 

realized by various methods, the most desirable method 
will be the repeated use of the last operand specifier. 
This point will be stated in detail later. 

There will now be explained an example in which 

20 the operand number specified by the operation code 
OP and the number of operand specifiers disagree. 
In a case where the operation code OP indicates, 
e.g., the processing of addition, the function is 
generally expressed by: 

.?5 A + B— > C 
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If A % B % C, it requires three operand specifiers. 
However, when, a plurality of identical operands are 
used as in case of A = B = C or A Jf B = C, an identi- 
cal operand specifier can be used a plurality of times. 
Therefore, the number of operands ascertained by the 
operation code and the number of operand specifiers 
do not always agree. 

For example, in the case of A = B = C, that is, 
in the processing of: 
A + A->A 

the identical operand specifier is used three times, 
whereby one operand specifier suffices. 

In the case of A ^ B = C, that is, in the 
processing of: . * 

A +. B — > B 

the second operand specifier is used twice, whereby 
the two operand specifiers suffice. 

In this manner, even in -Hie addition processing 
of the same operation code which ascertains the 
operand number of three, the different processing 
can be executed in accordance with the operand speci- 
fier numbers of one, two and three. 

Concrete examples of operand specifiers are 
shown in Figure 2(B). 

Here, Examples No. 1 - No. 24 are listed, and 
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the formats thereof and the corresponding operands 
are indicated in 1-to-l correspondence. 

In Figure 2(B), the ( ) of the operand designates 
the content of that address of a memory which is 
5 indicated by a value within ( ). 

In the format, DISP designates a displacement 
and IM 'immediate 1 (data direct), and a suffix 
denotes' the size thereof in terms of the number of bits. 
Further, R x designates an index register and R n 
10 a general register, and L denotes the size of the 
operand in byte. 

The relations between the f ormats and operands 
in Figure. 2(B) will be understood to some extent, but 
they will be briefly explained below. 
15 No. 1 is register direct addressing, in which 

the content of the general register, indicated by R n , 
itself becomes an operand directly. 

All of No. 2 and the following examples are 
operand specifiers which use the contents of a memory 
20 as operands, the addresses of the memory being 

calculated in forms indicated in the column of operands. 

No. 2 is indirect addressing, in which ttie content 
of the general register indicated by R n becomes the 
address of an operand. 
2 5 In each of Nos. 3, 5 and 7, a value indicated by 



- 12 - 



0073424 



DISP is added to the content of the general register 
indicated by R^ and the sum becomes the address of 
an operand. 

In Nos. 4, 6 and 8, the memory contents of the 
5 addresses obtained in Nos. 3, 5 and 7 become the 
addresses of operands, respectively. 

Nos. 9 — 11 are immediate data, in which Hie values 
of IMg, IM^g and IM^ 2 become operands in themselves. 
Nos. 12 - 17 differ from Nos. 3 - 8 in only the 
10 fact that a program counter PC is used instead of the 
general register R^ The PC holds an address next 
an operand specifier to be decoded. 

Nos. 18 - 24 are such that the values of the 
index register are further added to Nos. 5-8. 
15 In this case, the values of the index register R^ 
are multiplied by the data lengths L of operands 
(R x -L). 

This is a processing required for permitting the 
, value of the index register R x to be set as a dis- 
20 placement from the head irrespective of the data 
length L. 

That is, the multiplication by L (indicating 
the data length) allows the index register to 
store a value indicating No. of data as reckoned 
25 from the head, irrespective of the data length. 
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For example, when "10" is stored in the i-twiex 
register R it is the tenth data as reckoned from 
the head, and as the address thereof, 10 is automa- 
tically added (L = 1) when the data is a byte, 20 
5 (L = 2) when it is a word, or 40 (L = 4) when it is a 
long word, whereby the user can set the value of the 
index register irrespective of the data length. 

Figure 3 is a more concrete block diagram of the 
central processing unit 2 in Figure 1. 

10 In Figure 3, the parts of an instruction fetch 

unit (IFU) 25, an aligner (AUG) 26, a decode unit 
(DU) 27 and an address calculating unit (AU) 28 
correspond to the I unit 23 in Figure 1, and an ope- 
rand fetch unit (0FU) 29 and an execute unit (ED) 

15 30 correspond to the E unit 24. The arrangement of 
Figure 1 has been described to the effect that the I 
unit 23 and the E unit 24 perform the pipeline proces- 
sing. In the example shown in Figure 3, the respective 
units are further divided into the instruction fetch 

20 unit IFU 25, decode unit DU 27 and address calculat- - 
ing unit AU 28 and into the operand fetch unit OFU 
29 and execute unit 30, which perform pipeline proces- 
sing respectively. 

Since, however, the subject matter of the prese/it 

25 invention is not directly pertinent to such pipeline 
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processing themselves, detailed description on the 
pipeline processing is omitted. 

In Figure 3, the instruction fetch unit 25 has a 
program counter 50 for fetching an instruction in 
advance, which counter performs the processing of 
reading out previously the instruction to be subse- 
quently executed, from the instruction cache 21. 

An address desired to be read out is sent to the 
instruction, cache 21 via an address line 100, and the 
corresponding instruction of 4 bytes is transmitted 
to the instruction fetch unit IRJ 25 via a data line 
101. 

' In a case where the corresponding instruction " " - 
does not exist in the instruction cache 21, liie 
particular instruction is read out from the memory 1 
through the common bus 3 and is stored in the instruc- 
tion cache 21. The operations of the cache are well 
known, and are described in, e.g., «A Guide. to the IBM 
System/370 Model 168". 

When the instruction of 4 bytes has been trans- \ 
mitted to the instruction fetch unit 25, the program 
counter 50 is subjected to plus 4 ( + 4) and supplies 
the instruction cache 21 with a request for transmit- 
ting the next instruction. 

This operation is continued until a buffer (not 
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shown) disposed within the instruction fetch unit IFU 
25 is filled up. 

The instruction read out in advance is transmitted 
from the instruction fetch unit IFU 25 to the aligner 
(ALIG) 26 through a bus 103. 

The aligner 26 transmits the particular instruc- 
tion to a bus 104 after shifting it by the number of 
bytes instructed on a signal line 102 from the decode 
unit DU 27. Although the aligner ALIG 26 is shown 
here as being distinguished from the instruction fetch 
unit IRJ 25 f the former may well be considered as being 
included in the latter. 

By properly operating the value on the signal " * 
line 102, the bus 104 is supplied with the instruc- 
tion so that, as illustrated in Figure 5, when the 
first operand specifier of the instruction is to be 
processed, the operation code OP may be located at the 
left end and followed by the first operand specifier, 
while when the second or subsequent operand specifier 
is to be processed, the operand specifier may be 
arranged with a dummy of 1 byte preceding. The above 
control will be described in detail later. 

The decode unit (DU) 27 decodes the operation 
code and the operand specifiers transmitted from the 
aligner 26 (ALIG), and sends the following information 
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to the address calculating unit AU 28: 
(1) An addressing mode is sent through a bus 105. 

As explained before, there are the following 
addressing modes (a) - (h) , one of which is specified: 
5 (a) Register direct No. 1 

(b) R n No. 2 

(c) R^ + DISP type Nos. 3, 5 and 7 

(d) ^ + DISP indirect type Nos. 4, 6 and 8 

(e) Immediate Nos. 9, 10 and 11 

10 (f) PC + DISP type Nos. 12, 14 and 16 

(g) PC + DISP indirect type — - Nos. 13, 15 and 17 

(h) With indexes in (b) - (d) Nos. 18 - 24 

No. 1 — No. 24 correspond to those of the ' * 

operand specifier formats shown in" Figure 2(B). 
15 (2) The DISP or immediate data is sent in 32 bits 
through a bus 106. 

(3) The address of the general register R^ is sent 
through a bus 107. 

(4) The address of the index register R x is sent 
20 through a bus 108, and 

(5) the value of the program counter to be used for 
the address calculation is sent through . a bus 116. 

In accordance with the addressing mode indicated 
by the bus 105 and at any mode other than (a) and (e_), 
the address calculating unit AU 28 calculates the 
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address of an operand and delivers the calculated 
address to a bus 109. 

On the other hand, in case of (a), the content 
of the bus 107 is delivered to a bus 113 as it is, 
5 and in case of (e), the content of the bus 106 is 
delivered to the bus 109. 

In any mode other than (a) and (e), the operand 
fetch unit OFU 29 supplies a bus 110 with the content 
of the bus 109 indicative of the sent address. When 
10 the operand is "read", the unit 29 reqeusts the 

operand cache 22 to perform a read processing. , 

When a read operand has been delivered from 12ie 
operand cache 22 to a bus 111, the operand fetch unit 
OFU 29 delivers the read operand to the execute unit 
15 36 through a bus 112 and communicates to the effect 
that the operands' are ready. 

When the operand is "write", the operand fetch 
unit OFU 29 continues to deliver the address to the 
bus 110 until write- data from the execute unit EU 30 
20 is delivered to the bus HI. 

On the other hand, as regards the mode (a), the 
operand fetch unit OFU 29 accesses the general register 
(not shown) of its own on the basis of the register 
address 113 transmitted from the address calculating 
?- 5 unit AU 28. Only one difference from the other mode 
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than (a) is whether the memory or the register is 
accessed. 

Regarding (e), the unit 29 supplies the bus 111 
with the content of the bus 109 as it is and informs 
> the execute unit EO 30 to the effect that the operands 
are ready. 

In addition, the execute unit EU 30 receives 
the head address of a microprogram transmitted through 
an operation code bus 114 from the decode unit DU 
* 27, and it successively processes the instruction 
by employing the operands of the bus 112 in case of a 
"read" operand and by delivering -Qie operands (data) 
to the bus 111 in case of a "write" operand. 

Further, in a case "where the instruction is a 
branch instruction, a new program counter value is 
set in the program counter 50 of the instruction fetch 
unit IFU 25 or in a DP register 69 within the decode 
unit DU 27 to be stated later, and simultaneously, 
the processed results in the respective units on the 
operands precedently processed by the pipeline 
processing are cancelled, by the vise of a bus 115. 

The above is the outline of the processing for 
one operand specifier, and the respective units 
(25 - 30) perform the processing of the operand 
specifier in succession and in parallel by the pipeline 
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processing. 

Now, as to the decode unit 27 concerning the 
subject matter of the present invention, a concrete 
example will be mentioned and described in detail. 
5 Figure 4 is a block diagram showing the concrete 

embodiment of the decode unit DU depicted in Figure 3. 

The DP register 69 indicates the head of the inst- 
ruction to be decoded by the decode unit DU 27. In 
decoding the first operand specifier, it indicates 

10 the address of the operation code, and in decoding 
the second or subsequent operand specifier, it indi- 
cates the address of (the head of the particular 
operand specifier) - 1. 

The above address is transmitted to the aligner 

15 ALIG 26 and instruction fetch unit IFU 25 shown in 
Figure 3* through the bus 102. The bus 104 is 
simultaneously supplied from the aligner ALIG 26 
with plural bytes of data corresponding to the above 
address. As seen from Figure 5, the first byte of 

20 the bus 104 is supplied with the operation code OP 
as shown (A) in case of reading out the first 
operand specifier, or with dummy data as shown (B) 
in case of reading out the second or subsequent 
operand specifier. The second byte is supplied wit!} 

25 the operand specifier including the end flag S, and 
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the third to seventh "bytes are supplied with the 
other information of the particular operand specifier. 

A bus 204 affords an information indicating 
which operand is being processed. When the informa- 
tion indicates the end of the processing of all the 
operands, the first byte of the bus 104 is set in an 
operation code register 64. 

An output from the operation code register 64 
is -sent to a microprogram address generator (MAG) 
61 which finds the head address of the microprogram 
of the corresponding instruction in the execute unit 
30, and a decode sequence controller (DSC) 63 which 
provides information for the operands of "Hie corres- " 
ponding instruction. 

The output result 201 of idle MAG 61 is set in a~. 
head address register 62, and it is delivered to the 
execute unit EU 30 through the operation code bus 114 
in synchronism with the delivery of the first operand 
from the operand fetch unit OEU 29 to the execute unit 
EU 30. * 

The DSC 63 has, for example, an arrangement shown 
in Figure 6. Information as shown in Figure 6 are 
set in a ROM 82 beforehand, and are^read out by 
employing the operation code and the information 
indicative of the processing of Nos # of the operands 
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as addresses. 

More specifically, when the first byte has been 
set in the operation code register 64, the side of a 
bus 200 is selected by a selector SEL 81, and infor- 
5 mation on the first operand are read out with the 
operation code as an address. 

The information read out include: 

(1) the properties of the operand, namely, an infor- 
mation R/W of read operand or write operand and an 

10 information indicating the data length L (byte, word, 
long word) of the operand, 

(2) a flag E indicating the last of the operand, and 

(3) an address in which the information of the next — 
operand of the same instruction is stored. 

15 The information (l) are delivered to a bus 105-1 

and transmitted "to the address calculating unit AU 
28, and the information (2) is delivered to a bus 
203 and transmitted to a decode controller (DEC) 65. 
The information of Items (2) and (3) are latched 

20 in a register 83, and are used as the address for 
reading out the information on the next operand. 
Upon receiving the information E of Item (2) at its 
select terminal T, the selector 81 selects the side 
of the bus 200 (the side of the operation code regis r 

.25 ter 64) when the information E is "1", and the side 
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of the bus 204 (the next operand information 
address) when the information is "G l V 

Accordingly, when the information E is "G 11 , 
information on the operand are successively read out 
from the ROM 82. 

On the other hand, that signal line 205 within 
the bus 104 which indicates the end. flag S is 
connected to the decode . controller 65. 

Here, since the end flag S is indicated by one 
bit, it merely passes through an operand specifier 
decoder 66. However, in a case where the end infor- 
mation S itself is added to the operand specifier 
as one code signal, this signal is detected by the " "* 
operand specifier decoder 66 so as to check if the 
particular operand specifier is the last .operand 
specifier. 

In addition, the head 7 bits of the operand 
specifier are sent to the operand specifier decoder 
66 by a bus 206. 

The operand specifier is decoded by the infor- 
mation of 7 bits, and an example of the decoding will 
be explained with reference to Figure 7. 

When, by way of example, the operand specifier 
(R n + DISP 8 ) indicated at No. 3*in Figure 2(B) has 
been sent, it is detected that 3 bits in the upper 7 
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bits are 010 as shown in Figure 7(A), whereby the 
following five information can be provided: 

(1) The operand specifier has a length of 2 bytes. 

(2) In a case where the content of a bus 208 is 

5 delivered to the bus 106, the right shift of 3 bytes 
is necessary for adjusting the digit of the DISP. 

(3) In order to render the DISP value 4 bytes, the 
upper 3 bytes shall be provided by code-expanding the 
most significant bit (M) of the DISP Q . 

10 (4) With R n + DISPg, the address of the operand can 
be calculated. 

(5) The information of exists in the lower 4 bits 
of the first byte. 

Likewise, when (R n + DISP 32 ) at No. 7 in Figure 2(B) 
15 has been sent, it is detected that the upper 7 bits 
except the end flag bit S are 1110110 as shown in 
Figure 7(B) , whereby the following five information 
can be provided: 

(l) The operand specifier has a length of 6 bytes. 
20 (2) In a case where the content of the bus 208 is 

delivered to the bus 106, the left shift of 1 byte 

is necessary for adjusting the digit of the DISP. 

(3) Since the DISP has all 32 bits specified, it must 

be provided as it is, 
25 (4) With + DISP 32 , the address of the operand can 
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be calculated* 

(5) The information of R^ exists in the lower 4 bits 
of the second byte of the operand specifier. 

While the two examples have been mentioned above, 
5 they are summed up as follows: 

The operand specifier decoder 66 decodes the 
operand specifier sent in, and provides respective 
information mentioned below. 

(1) A bus 215 is supplied with the length of the 
10 operand specifier. By way of example, when the 

operand specifier (R n + DISPg) which is the operand 
specifier No. 3 in Figure 2(B) has been sent in, "2" 
is provided. 

(2) A bus 211 is supplied with the number of shift 
15 bytes for an aligner .67 for displacement (DISP)/ 

immediate (IM) data* 

For example , in case of the operand specifier 
(F^ + DISPq), the right shift of 3 bytes is instructed 
as shown in Figure 7(A) , and in case of (R^ + DISP^) , 
20 the left shift of 1 byte as shown in Figure 7(B). 

(3) A bus 212 is supplied with instruction data of 
mask bytes for the aligner 67. 

That is , in the data of 4 bytes which are 
delivered to the bus 106 for the aligner 67, the ma§k 
25 of the upper 2 bytes or 3 bytes is instructed, whereby 
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the DISP or IM information of 1 byte or 2 bytes can 
be rendered 4 bytes by the code expansion. 

For example, the DISPg is shifted by 3 bytes as 
shown in Figure 7(A), and the DISP^ 2 is shifted 
leftward by 1 byte because it is preceded by one 
surplus byte of "-F^ 11 , as shown in Figure 7(B) . 

The reason is that, unless the upper 3 bytes of 
the DISPg have therein the code bits of the DI3P Q a,s 
expanded, the normal address calculation of 32 bits 
cannot be performed. (The bus 212 serves for the 
specification thereof.) 

(4) A bus 105-2 is supplied with an addressing mode, 
by which the operating mode of the address calculating 
unit AO 28 is instructed. 

Regarding the addressing modes, the presence of 
the 8 modes (a) -(h) has already been explained in 
connection with the description of the address 
calculating unit AU 28 in Figure 3. 

(5) A bus 216 is supplied with an information indicat- 
ing whether the position in which the general register 
R n exists is the first byte or the second byte. 

The first byte is indicated for the (F^ + DISPg), 
and the second byte for the (R n + DISP^). 

On the other hand, the bus 108 is supplied with- 
the part of the index register R in the operand 
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specifier. 

Depending upon the position where the general 
register exists, indicated by the signal 216 (the 
signal indicative of the first byte or the second 
5 byte), the selector 68 supplies the bus 107 with a 
part corresponding to the (the content of a bus 207 
or the content of a bus 210) . 

Since the aligner 67 is given the second to 
seventh bytes of the operand specifier by the bus 208 
10 as stated before, it performs the shift processing by 
the shift number given by the signal line 211 and also 
performs the code expansion for the mask part given 
by the signal line 212, thereby to deliver the data of 
4 bytes to the bus 106. 
15 These are as shown in Figures 7(A) and 7(B), 

Now, the decode controller 65 will be described. 
This portion is also the essential part in the 
case of handling the variable-length instruction 
(with the S bit added) according to the present inven- 
20 tion. 

As stated previously, the decode controller 65 
has the three input signal lines of the signal line 
203 indicating the operand end flag E, the signal 
line 205 indicating the end flag S of the operand / 
-25 specifier, and the signal line 215 indicating the byte 
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number (OSg) of the operand specifier. It delivers 
the added value DPINCg of the DP 69 to a signal 
line 214 in byte unit. The algorithm in this case 
is as follows: 
5 If E = l, 

DPINCg « OS B 
Otherwise, at S = 0, 
DPINCg » OSg - 1 
and at S = 1, 
10 DPINCg = 0 

That is, 

(1) in a case where the end f lag E of the operand is 
"1", all the operands of the corresponding instruction 
have been obtained, and hence, in order to po'int at 

15 the head of the next instruction, the output is deli- 
vered to the signal line 214 so that the content of 
the DP register 69 may have the byte number (GS^) of 
the operand specifier added thereto. 

(2) In a case other than (1), namely, in a case 
20 where E = 0 and where the end flag S is not set 

yet, the output is delivered to the signal line 214 
so that the value of (the number of bytes of the 
operand specifier: 0S £ ) - 1 may be added, in order 
to deliver the next operand specifier to the bus 104, 
25 with the dummy of 1 byte located at the head byte. 
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(3) In a case other than (l) , namely, in a case where 
E = 6 and where the end flag S is set, "0" is provided 
so that the DP register 69 may hold its value intact. 
Thus, the same operand specifier is used for the 
5 processing, of the next operand and is used repeatedly. 

Figure 8 shows a hardware arrangement which 
realizes the algorithm in the decode controller 65. 

In the case of E = 1, an output gate 301 is enabled 
to deliver the content 0S B of the bus 215 to the bus 
10 214, while in the case of E = 0, at S = 0, a gate 
307 turns "on 11 and an output gate 303 is enabled to 
deliver OSg - 1, and at S = 1, a gate 306 turns 
"on" and an output gate 302 is enabled to deliver "6". 

Unless the S bit is 1 when E is 1, it is meant 
15 that operand specifiers larger in number than operands 
exist. In Figure 8, an AND gate 309 turns "on" to pro- 
vide an error signal 105—3 and to communicate the 
occurrence of - the error, to the address calculating 
unit AU 28. 

20 The address calculating unit AU 28 communicates - 

the error signal 105-3 to the ensuing unit (operand 
fetch unit OEU 29), and the occurrence of the error 
is finally communicated to the execute unit EU 30. 
In Figure 8, numerals 304 and 305 designate 

"25 inverters, numerals 306, 307 and 309 AND gates, and 
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numeral 308 a subtracter for (0S Q - 1). 

An adder 71 adds the current value of the DP 
register 69 and that of the signal line 214 and sets 
the sum in the DP register 69 through a selector 70. 
5 Thus, the address of the next operand specifier is 
supplied to the bus 102. In this way, the aligner 
. ALIG 26 can deliver the next operand specifier to the 
bus 104 in the format shown in Figure 5(A) or (B). 

On the other hand, the content of the bus 115 is 
10 selected by the selector 70 and set in the DP register 
69, whereby the change of the content of the DP regis- 
ter 69 in the foregoing branch instruction is also 
permitted. 

An adder 72 adds the value (OSg) of the 'signal 
15 line 215 indicating the length of the corresponding 

operand specifier, to the value of the DP register 

69 and further adds a carry input "1" , thereby to 

supply the bus 116 with an address next the operand 

specifier being decoded. 
20 The address calculating unit AU 28 utilizes the ■ 

content of the bus 116 as the value of the program 

counter PC for the address calculation. 

In this manner, according to the present invention, 

there is the feature that the operation code and the^- 
25 operand specifier are independent and that the length 
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of the operand specifier can be arbitrarily set. In 
addition, using one operation code, both the instruc- 
tions of the A (0£) B — > C type and the instructions 
of the A C0P3 B — > B type can be expressed with the 
5 optimum amounts of information of the respective 

instructions, so that the number of instructions which 
can be specified by the operation codes of equal lengths 
increases. 

That is, in a case where operation code lengths 

10 are equal, a larger number of high function instructions 
can be added in accordance with the present invention. 

Moreover, the error detection rate can be enhanced 
by performing the reasonable check of the number of 
operands and the number of operand specifiers. 

15 While, in the foregoing embodiment, the end flag 

S is added to the most significant bit of the operand 
specifier, the position need not always be restricted 
to this part, but the end flag may be provided in any 
place of the operand specifier. 

20 In the foregoing embodiment, utilizing the same' *. 

operand repeatedly a plurality of times is realized 
by repeatedly decoding the same operand specifier 
without renewing the content of the DP register 69. 
Alternatively, a special signal may be sent from the^. 

?- 5 decode unit to the execute unit EU 30 so as to instruct 

the repeated utilization of the operand previously obtained. 
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CLAIMS: 

1 . A central processing unit for executing instructions 
of variable length in which an operand specifier for 
specifying the addressing mode of an operand is independent 
of an operation code for ascertaining the kind of an 
5 operation and the number of operands, comprising: 

(A) instruction fetch means (25) for fetching an 
instruction from memory means storing instructions and 
operands , 

(B) decoding means (27) connected to said instruction 
10 fetch means (25) and for decoding an operation code and an 

operand specifier, 

(C) address calculating means (28) connected to said 
decoding means (25) and for calculating an address of an 
operand on the basis of the decoded result of the operand 

15 specifier from said decoding means, 

(D) operand fetch means (29) connected to said address 
calculating means (28) and for fetching the operand 

from said memory means on the basis of the calculated 
address, and 

20 (£) executing means (30) connected to said operand 

fetch means (29) as well as said decoding means (27) and 
for executing the instruction successively by the use of 
the operands from said, operand fetch means (29) and in 
accordance with the decoded results of the operation 

25 codes from said decoding means (27) , 
said decoding means (27) including: 
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(i) operation code decoding means (63 , 65) for decoding 
the operation codes of the instruction and delivering 
information on the operands in operand unit, and 

(ii) operand specifier decoding means (66) for decoding 
5 information added to specific fields of the respective 

operand specifiers, on whether or not the particular 
operand specifier is the last operand specifier. 

2. A central processing unit according to claim 1, wherein 
said decoding means (27) includes means (65) for deciding 
10 that the decoding of one instruction has ended, upon 

receiving the information indicative of the last operand 
from said operation code decoding means and the information 
indicative of the last operand specifier from said 
. operand specifier decoding means. 

15 3. A central processing unit according to claim 1, wherein 
said decoding means includes means (65) for causing the 
operand specifier to be used again, in a case where when 
the information indicative of the last operand specifier 
has been received from said operand specifier decoding 

20 means, the information indicative of the last operand is 
not received from said operation code decoding means. 

4. A central processing unit according to claim 1, wherein 
-■*" said decoding means (27) includes error detection means 

for detecting the instruction as an error, in a case where 
25 when the information indicative of the last operand has been 
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received from said operation code decoding means (66), 
said operand specifier decoding means (66) does not receive 
the information indicative of the last operand 
specifier. 

5 5. A central processing unit according to claim 1, wherein 
said decoding means (27) includes means (83) for supplying 
said instruction fetch means v/ith a signal for obtaining 
the operand specifier to be decoded next, each time the 
decoding of one operand specifier ends. 

6. A central processing unit according to claim 1, wherein 
the instruction is formed of the operation code of one to 
plural bytes and the operand specifier of one to plural 
bytes, and said operand specifier decoding means (66) in- 
cludes means for decoding the first byte of said each 
operand specifier and delivering the information on whether 
or not the particular operand specifier is the last operand 
specifier. 
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